TimeZone এবং Locale এর সাথে কাজ

Date এবং Calendar ক্লাস - জাভা ইউটিল.প্যাকেজ (Java.util Package) - Java Technologies

310

java.util প্যাকেজে TimeZone এবং Locale ক্লাস দুটি গুরুত্বপূর্ণ ক্লাস, যা বিভিন্ন ধরনের টাইম জোন এবং লোকালাইজেশন (ভাষা, অঞ্চল) সম্পর্কিত কার্যাবলী পরিচালনা করতে ব্যবহৃত হয়। এই ক্লাসগুলি আপনাকে আপনার প্রোগ্রামটি বিশ্বব্যাপী ব্যবহারকারীদের জন্য আরও উপযোগী করে তোলে, কারণ আপনি টাইম জোন এবং লোকাল সেটিংস এর উপর ভিত্তি করে সময় এবং তারিখের সাথে কাজ করতে পারেন।

1. TimeZone Class

TimeZone ক্লাসটি বিশ্বের বিভিন্ন টাইম জোন পরিচালনা করার জন্য ব্যবহৃত হয়। এটি Date, Calendar, এবং ZonedDateTime এর মতো ক্লাসগুলির জন্য টাইম জোন সম্পর্কিত কার্যাবলী প্রদান করে। TimeZone এর মাধ্যমে আপনি একটি নির্দিষ্ট অঞ্চল বা টাইম জোন অনুযায়ী তারিখ ও সময় কনভার্ট করতে পারেন।

TimeZone Class এর ব্যবহারের উদাহরণ

import java.util.TimeZone;
import java.util.Date;

public class TimeZoneExample {
    public static void main(String[] args) {
        // Default TimeZone (system time zone)
        TimeZone defaultTimeZone = TimeZone.getDefault();
        System.out.println("Default TimeZone: " + defaultTimeZone.getID());

        // Get the time zone for a specific location
        TimeZone tzNewYork = TimeZone.getTimeZone("America/New_York");
        System.out.println("Time Zone for New York: " + tzNewYork.getID());

        // Get the time zone for UTC
        TimeZone tzUTC = TimeZone.getTimeZone("UTC");
        System.out.println("Time Zone for UTC: " + tzUTC.getID());

        // Get the current date and time in a specific time zone
        Date currentTime = new Date();
        System.out.println("Current Date and Time in UTC: " + currentTime.toString());
    }
}

Output:

Default TimeZone: Asia/Kolkata
Time Zone for New York: America/New_York
Time Zone for UTC: UTC
Current Date and Time in UTC: Mon Dec 23 12:48:24 UTC 2024

ব্যাখ্যা:

  • TimeZone.getDefault() মেথডটি সিস্টেমের ডিফল্ট টাইম জোন (যেটি আপনার কম্পিউটারের টাইম জোন অনুযায়ী হবে) ফেরত দেয়।
  • TimeZone.getTimeZone(String id) মেথডের মাধ্যমে নির্দিষ্ট টাইম জোন যেমন America/New_York বা UTC এর জন্য টাইম জোন পাওয়া যায়।
  • Date অবজেক্টটি সিস্টেমের টাইম জোনে ভিত্তি করে তারিখ এবং সময় প্রদান করে।

TimeZone Class এর প্রধান মেথড:

  1. getDefault(): সিস্টেমের ডিফল্ট টাইম জোন ফেরত দেয়।
  2. getTimeZone(String id): নির্দিষ্ট টাইম জোনের তথ্য ফেরত দেয়।
  3. getID(): টাইম জোনের আইডি ফেরত দেয় (যেমন "America/New_York")।
  4. getOffset(long date): একটি নির্দিষ্ট তারিখের জন্য টাইম জোনের UTC থেকে পার্থক্য ফেরত দেয়।

2. Locale Class

Locale ক্লাসটি ভাষা, দেশ, এবং সংস্কৃতি সম্পর্কিত তথ্য ধারণ করে। এটি মূলত বিভিন্ন ভাষা এবং অঞ্চলের জন্য ফরম্যাটিং এবং লোকালাইজেশন (যেমন তারিখ, সময়, সংখ্যা ফরম্যাট) এর কাজ করতে ব্যবহৃত হয়। আপনি Locale ব্যবহার করে সিস্টেমের লোকাল সেটিংস পরিবর্তন করতে এবং বিভিন্ন দেশের ভাষা, সংস্কৃতি অনুযায়ী অ্যাপ্লিকেশন কাস্টমাইজ করতে পারেন।

Locale Class এর ব্যবহারের উদাহরণ

import java.util.Locale;

public class LocaleExample {
    public static void main(String[] args) {
        // Create Locale object for a specific country and language
        Locale localeUS = new Locale("en", "US");
        System.out.println("Locale for US: " + localeUS.getDisplayName());

        // Create Locale object for a specific language (French)
        Locale localeFrance = new Locale("fr", "FR");
        System.out.println("Locale for France: " + localeFrance.getDisplayName());

        // Default system locale
        Locale defaultLocale = Locale.getDefault();
        System.out.println("Default Locale: " + defaultLocale.getDisplayName());
    }
}

Output:

Locale for US: English (United States)
Locale for France: français (France)
Default Locale: English (United States)

ব্যাখ্যা:

  • Locale("en", "US") এবং Locale("fr", "FR") দ্বারা নির্দিষ্ট দেশের এবং ভাষার লোকাল তৈরি করা হয়েছে।
  • getDisplayName() মেথড ব্যবহার করে একটি লোকাল অবজেক্টের পূর্ণ নাম (ভাষা এবং দেশসহ) প্রদর্শন করা হয়েছে।
  • Locale.getDefault() মেথডটি সিস্টেমের ডিফল্ট লোকাল ফেরত দেয়।

Locale Class এর প্রধান মেথড:

  1. getDefault(): সিস্টেমের ডিফল্ট লোকাল ফেরত দেয়।
  2. getDisplayName(): লোকাল অবজেক্টের নাম (ভাষা এবং দেশ) প্রদান করে।
  3. getLanguage(): লোকালের ভাষা কোড প্রদান করে (যেমন "en" বা "fr")।
  4. getCountry(): লোকালের দেশ কোড প্রদান করে (যেমন "US" বা "FR")।

TimeZone এবং Locale এর ব্যবহার একত্রে:

আপনি যখন TimeZone এবং Locale একসাথে ব্যবহার করেন, তখন আপনি নির্দিষ্ট টাইম জোন এবং লোকাল সেটিংসের ভিত্তিতে তারিখ ও সময় ফরম্যাট করতে পারেন।

উদাহরণ: TimeZone এবং Locale সহ Date Format

import java.util.*;
import java.text.*;

public class TimeZoneLocaleExample {
    public static void main(String[] args) throws ParseException {
        // Set Locale and TimeZone
        Locale locale = new Locale("en", "US");
        TimeZone timeZone = TimeZone.getTimeZone("America/New_York");

        // Create a Calendar instance with the specific locale and time zone
        Calendar calendar = Calendar.getInstance(locale, timeZone);

        // Set a specific date
        calendar.set(2024, Calendar.DECEMBER, 25, 10, 30);

        // Format the date
        SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss", locale);
        sdf.setTimeZone(timeZone);

        System.out.println("Formatted Date (New York, US): " + sdf.format(calendar.getTime()));
    }
}

Output:

Formatted Date (New York, US): 2024-12-25 10:30:00

ব্যাখ্যা:

  • এখানে TimeZone এবং Locale একত্রে ব্যবহার করা হয়েছে। Calendar.getInstance() মেথডের মাধ্যমে নির্দিষ্ট টাইম জোন এবং লোকাল সেটিংস অনুযায়ী সময় তৈরি করা হয়েছে।
  • SimpleDateFormat এর মাধ্যমে নির্দিষ্ট টাইম জোন এবং লোকাল অনুযায়ী তারিখ এবং সময় ফরম্যাট করা হয়েছে।

  • TimeZone এবং Locale ক্লাসগুলি ব্যবহার করে আপনি টাইম জোন এবং লোকাল সেটিংসের উপর ভিত্তি করে সময় এবং তারিখ সম্পর্কিত কাজগুলো খুব সহজে এবং সঠিকভাবে করতে পারবেন। এগুলির মাধ্যমে আপনি একটি worldwide application তৈরি করতে সক্ষম হবেন, যা বিভিন্ন টাইম জোন এবং ভাষার ভিত্তিতে ব্যবহারকারীর জন্য নির্দিষ্ট তথ্য প্রদান করবে।
  • TimeZone ক্লাস সময়ের ব্যবধান এবং টাইম জোন সম্পর্কিত কাজগুলো সহজ করে এবং Locale ক্লাস ভাষা, সংস্কৃতি এবং অঞ্চলের ওপর ভিত্তি করে অ্যাপ্লিকেশন কাস্টমাইজেশন করতে সহায়তা করে।
Content added By
Promotion

Are you sure to start over?

Loading...